package main

import (
	"encoding/json"

	"jlpay-sdk-go/pkg/jlpay/demo"
	"jlpay-sdk-go/pkg/jlpay/models/openmerch/device"
	device2 "jlpay-sdk-go/pkg/jlpay/services/openmerch/device"
	"jlpay-sdk-go/pkg/jlpay/utils"
)

// 设备变更示例
func deviceChangeDemo(deviceService *device2.DeviceService) {
	// 构建请求参数
	requestData := map[string]interface{}{
		"merch_no":      "84944035812S123",
		"term_no":       "S1002513",
		"new_device_no": "NS301257964",
	}

	request := device.NewDeviceChangeRequest()
	request.SetRawRequestMap(requestData)

	// 序列化请求数据并打印
	requestJSON, _ := json.Marshal(requestData)
	utils.Debugf("设备变更请求数据: %s", string(requestJSON))

	// 发送请求
	response, err := deviceService.ChangeDevice(request)
	if err != nil {
		utils.Errorf("设备变更请求失败: %v", err)
		return
	}

	// 处理响应 - 使用BaseResponse接口的HandleResponse方法
	response.HandleResponse("设备变更")
}

func main() {
	// 设置日志级别为info，显示详细的调试信息
	utils.SetLogLevel("info")

	utils.Info("=============================")
	utils.Info("===== 设备变更示例 开始 =====")
	utils.Info("=============================")

	// 创建配置对象和设备服务
	config := demo.CreateDemoConfig()
	deviceService := device2.NewDeviceService(config)

	deviceChangeDemo(deviceService)

	utils.Info("=============================")
	utils.Info("===== 设备变更示例执行完毕 =====")
	utils.Info("=============================")
}
